

16-bit instruction if ABCDE is in range 00000 to 11100:

**PRIOR ART** 

32-bit instruction if ABCDE is 11101, 11110 or 11111:

First halfword (HW1) Second halfword (HW2)
15 11 10 0 15 0
+----+
| ABCDE | xxxxxxxxxxx | | xxxxxxxxxxxxx |

FIG. 3

ARM coprocessor instructions with bits[27:24] = 1100 or 1101:

31 28 27 25 24 23 22 21 20 19 16 15 12 11 8 7 4 3 0

| cond | 110 | 0 | 0 | 0 | 0 | x | xxxx | xxxx | cpnum | xxxxxxxx |

Undefined

| cond | 110 | 0 | 0 | 1 | 0 | 0 | Rn | Rd | cpnum | opc | CRm | MCRR

| cond | 110 | 0 | 0 | 1 | 0 | 1 | Rn | Rd | cpnum | opc | CRm | MRRC

| cond | 110 | P | U | N | W | 0 | Rn | CRd | cpnum | offset | STC

| cond | 110 | P | U | N | W | 1 | Rn | CRd | cpnum | offset | LDC

Note: (P,U,W) != (0,0,0) on the LDC and STC rows.

ARM coprocessor instructions with bits{27:24] = 1110:

| 31 2 |    |    |     |       |        |      |    |          |      |    |      |   |   |     |   |     |
|------|----|----|-----|-------|--------|------|----|----------|------|----|------|---|---|-----|---|-----|
| cond | 11 | 10 | op  | c1    | C      | Rn   | CF | ₹đ       | cpnu | ım | opc  | 2 | 0 | CRm | 1 | CDP |
| cond | 11 | 10 | opc | 1   0 | )   C1 | Rn   | Ro | 1        | cpnu | m  | opc  | 2 | 1 | CRm | 1 |     |
| cond | 11 | 10 | opc | 1   3 | .  CI  | ≀n ≀ | Ro | <b>i</b> | cpnu | .m | opc: | 2 | 1 | CRm | 1 | MRC |

FIG. 4
PRIOR ART

Coprocessor instructions in the enhanced Thumb instruction set:

With HW1[11:8] = 1100 or 1101:

```
First halfword (HW1)

15 12 11 9 8 7 6 5 4 3 0 15 12 11 8 7 4 3 0

| 111x | 110 | 0 | 0 | 0 | x | xxxx | xxxx | cpnum | xxxxxxxx |

Undefined

| 111x | 110 | 0 | 0 | 1 | 0 | 0 | Rn | Rd | cpnum | opc | CRm | MCRR

| 111x | 110 | 0 | 0 | 1 | Rn | Rd | cpnum | opc | CRm | MRRC

| 111x | 110 | P | U | N | W | 0 | Rn | CRd | cpnum | offset | STC

| 111x | 110 | P | U | N | W | 1 | Rn | CRd | cpnum | offset | LDC
```

Note: (P,U,W) := (0,0,0) on the LDC and STC rows.

With  $HW1{11:8} = 1110:$ 

| First halfwor<br>15 12 11 8 | 7 5      | 1 3 0 | 15 12 | 11 8  | 7 5  | 4 3   | 0        |
|-----------------------------|----------|-------|-------|-------|------|-------|----------|
| 111x   1110                 | opc1     | CRn   | CRd   | cpnum | opc2 | 01 C  | Rm   CDP |
| 111x   1110<br>+            | opc1   ( | CRn   | Rd    | cpnum | opc2 | 1   C | Rm   MCR |
| 111x   1110                 | opc1   1 | CRn   | Rd    | cpnum | opc2 | 1   C | Rm   MRC |

FIG. 5

|      |                                   |                 | · · · · · · · · · · · · · · · · · · ·         |    |
|------|-----------------------------------|-----------------|-----------------------------------------------|----|
|      | inconditional instruction 5 4 3 0 | Byte<br>address | Thumb unconditional CDP instruction 7 5 4 3 0 |    |
| opc2 | 2   0   CRm                       | A               | opc1   CRn   )                                |    |
| CF   | d   cpnum                         | A+1             | ++ ) HV                                       | ۸T |
| opc  | :1   CRn                          | A+2             | opc2   0   CRm   )                            |    |
|      | 11x1110                           | A+3             | CRd   cpnum   )                               | 12 |
| +    | +                                 |                 | +                                             |    |

FIG. 6



FIG. 7 PRIOR ART



FIG. 8 PRIOR ART



FIG. 9



FIG. 10